草庐IT

visual-studio-code - Flutter VS 代码问题

全部标签

ruby - 一个文件中的多个类,Ruby 风格问题

我正在编写一个脚本,它从数据库中获取数据并根据解析的数据创建GoogleChartURL。我只需要创建两种类型的图表,饼图和条形图,如果我将这两个类放在同一个文件中只是为了保持我拥有的文件数量较少,这是错误的吗?谢谢 最佳答案 如果你问的是“ruby”方式,那就是将你的类放在单独的文件中。正如其他一些人所暗示的那样,将您的类放在单独的文件中可以更好地扩展。如果您将多个类放在同一个文件中并且它们开始增长,那么稍后您将需要将它们分开。那么为什么不从一开始就将它们分开呢?更新我还应该提到自动加载的工作原理是期望类位于它们自己的文件中。例如

ruby - 作为开发人员,不同的 Ruby 线程模型(Ruby 与 JRuby)对您的代码有什么实际影响?

我试图了解MRIRuby1.8和JRuby之间不同线程模型的实际影响。作为开发者,这种差异对我意味着什么?另外,MRIRuby1.8中是否有任何实际代码示例会由于不同的线程模型而在JRuby上具有更差的性能特征? 最佳答案 状态ruby1.8有绿色线程,这些线程可以快速创建/删除(作为对象)但不是真正的并行执行,甚至不由操作系统调度,而是由虚拟机调度ruby1.9有真正的线程,由于操作系统调用,创建/删除(作为对象)很慢,但由于GIL(全局解释器锁)一次只允许一个线程执行,所以这些都不是真正的线程并行JRuby也有操作系统调度的真实

Ruby:在代码中使用 rand() 但编写测试来验证概率

我有一些代码可以根据加权随机数提供内容。权重越大的东西越有可能被随机选择。现在作为一名优秀的ruby​​ist,我当然想用测试覆盖所有这些代码。我想测试是否根据正确的概率获取了东西。那么我该如何测试呢?为应该是随机的东西创建测试使得很难比较实际与预期。我有一些想法,以及为什么它们不会很好地工作:在我的测试中stubKernel.rand以返回固定值。这很酷,但是rand()被调用了多次,我不确定我是否可以通过足够的控制来装备它来测试我需要的东西。多次获取随机项目,并将实际比率与预期比率进行比较。但除非我可以无限次地运行它,否则这永远不会完美,并且如果我在RNG中运气不佳,可能会间歇性地

ruby-on-rails - 如何将 Ruby 变量放入正则表达式代码中

我正在运行grep方法以通过模式匹配进行过滤。这是示例代码。companies.grep/city/但是,ruby不允许我在railsView内的block中输入area_code。相反,我不得不像这样对其进行硬编码:companies.grep/miami/请记住,城市是一个变量。例如,city=miami但是,它会更新。你知道如何通过grep方法传递变量吗?此外,我尝试了companies.grep/#{city}/,但没有成功 最佳答案 companies.grep/#{city}/#orcompanies.grepRegex

ruby-on-rails - Rails v3/Ruby 1.9.2 中的字符编码问题

当我从文件中读取内容时,有时会收到此错误“UTF-8中的无效字节序列”。注意-只有当字符串中有一些特殊字符时才会发生这种情况。我尝试打开不带“r:UTF-8”的文件,但仍然出现同样的错误。open(file,"r:UTF-8").each_line{|line|putsline.strip(",")}#line.stripgeneratestheerror文件内容:#encoding:UTF-8290919,"SE","26","Sk‰l","",59.4500,17.9500,,#thiserrorsout290956,"CZ","45","HornÌBradlo","",49.80

ruby - Ruby 和 Net::SCP 传输(套接字)的性能问题

从命令行scp实用程序的功能来看,SCP上传速度似乎在库中受到很大限制。我知道这是Ruby(1.9.2-p0),但是Net::SCP比Linux实用程序慢大约8倍(使用大文件看到...见下文)。我很好奇知道(我快速查看了代码)这是否是Ruby中套接字的方式,或者是否可以更好地多路复用Net::SCP套接字?我注意到无论我尝试哪种上传方式(串行上传、异步操作channel、使用scp对象的多个实例)我都无法在SCP上传上获得超过9兆字节/秒的传输速度。现在……让我解释一下我调查的细节:1)尝试不同的加密算法我使用了不同类型的加密,速度没有太大变化示例:我可以使用命令行scp(加密算法=a

ruby-on-rails - Rails 3 到 4 迁移唯一性验证问题

上下文我们正在从Rails3.2.12迁移到4.0.2,从Ruby1.9.3迁移到2.1.8。我们有很多测试覆盖率以RSpec的形式完成迁移。问题检查卡片模型的唯一性验证是否失败的规范之一。validates:mobile,uniqueness:{scope::program_member_id,message:I18n.t('models.card.error.cardholder_already_has_mobile')},if::mobileprogram_member可能只有一张mobile:true卡。规范为成员(member)创建2张卡,将其中一张变成移动卡,然后在使用第二

ruby - 在 rcov 中,有没有办法找到哪个测试方法遍历了被测试的给定代码行?

在rcov中,有没有办法找到跟踪哪些测试方法覆盖了给定的代码行(在您正在测试的目标代码中)? 最佳答案 我很确定,rcov不支持此功能。由于CoverageInfo的文档Class建议,rcov只跟踪给定的linen是否被执行,而不是在什么上下文中执行。 关于ruby-在rcov中,有没有办法找到哪个测试方法遍历了被测试的给定代码行?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions

ruby - I18n::InvalidLocaleData:I18n gem 在 js 导出中有问题

我正在OSX10.13.4上使用Rails3.2.22.4、Ruby2.2.7开发一个应用程序。有多个翻译文件,例如。en.yml,sq.yml基于国家。从下面的ruby​​mine执行命令时,加载网页时出现错误。rake--tracei18n:js:export来自en.yml的yaml内容已经过验证并且是正确的。从文件中删除后引发错误的特定行将在其他一些.yml文件中给出错误。正在使用当前版本的gemi18n(0.9.5)。Rails服务器启动但加载Web应用程序第一页时因同样的错误而中断。代码遇到i18n翻译代码时抛出错误,当错误从一个文件转移到另一个文件时,yml格式不是问题。

ruby - 为什么我的带有 ANSI 颜色代码的 IRB 提示通过复制/粘贴弄乱了翻页/翻页行为?

我添加到我的.irbrc:IRB.conf[:PROMPT].reverse_merge!(:RAILS_ENV=>{:PROMPT_I=>"#{current_app}#{rails_env}#{prompt}",:PROMPT_N=>"#{current_app}#{rails_env}#{prompt}",:PROMPT_S=>nil,:PROMPT_C=>"?>",:RETURN=>"=>%s\n"})IRB.conf[:PROMPT_MODE]=:RAILS_ENV如果我这样做:current_app="\e[31mfoo_bar_app\e[0m"rails_env="\e